# CHAPTER THREE COMMON DIGITAL COMPONENTS

## 2-2 Decoders

Discrete quantities of information are represented in digital computers with binary codes. A binary code of n bits is capable of representing up to  $2^n$  distinct elements of the coded information. A decoder is a combinational circuit that converts binary information from the n coded inputs to a maximum of  $2^n$  unique outputs. If the n-bit coded information has unused bit combinations, the decoder may have less than  $2^n$  outputs.

The decoders presented in this section are called n-to-m-line decoders, where  $m \le 2^n$ . Their purpose is to generate the  $2^n$  (or fewer) binary combinations of the n input variables. A decoder has n inputs and m outputs and is also referred to as an  $n \times m$  decoder.

The logic diagram of a 3-to-8-line decoder is shown in Fig. 2-1. The three data inputs,  $A_0$ ,  $A_1$ , and  $A_2$ , are decoded into eight outputs, each output

decoder



Figure 2-1 3-to-8-line decoder.

representing one of the combinations of the three binary input variables. The three inverters provide the complement of the inputs, and each of the eight AND gates generates one of the binary combination. A particular application of this decoder is a binary-to-octal conversion. The input variables represent a binary number and the outputs represent the eight digits of the octal number system. However, a 3-to-8-line decoder can be used for decoding any 3-bit code to provide eight outputs, one for each combination of the binary code.

Commercial decoders include one or more enable inputs to control the operation of the circuit. The decoder of Fig. 2-1 has one enable input, *E*. The decoder is enabled when *E* is equal to 1 and disabled when *E* is equal to 0.

The operation of the decoder can be clarified using the truth table listed in Table 2-1. When the enable input E is equal to 0, all the outputs are equal to 0 regardless of the values of the other three data inputs. The three  $\times$ 's in the table designate don't-care conditions. When the enable input is equal to 1, the decoder operates in a normal fashion. For each possible input combination, there are seven outputs that are equal to 0 and only one that is equal to 1. The output variable whose value is equal to 1 represents the octal number equivalent of the binary number that is available in the input data lines.

Enable input

| Enable | Inputs         |       |       | Outputs        |                |                |                |       |       |       |       |
|--------|----------------|-------|-------|----------------|----------------|----------------|----------------|-------|-------|-------|-------|
| E      | A <sub>2</sub> | $A_1$ | $A_0$ | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | $D_2$ | $D_1$ | $D_0$ |
| 0      | ×              | ×     | ×     | 0              | 0              | 0              | 0              | 0     | 0     | 0     | 0     |
| 1      | 0              | 0     | 0     | 0              | 0              | 0              | 0              | 0     | 0     | 0     | 1     |
| 1      | 0              | 0     | 1     | 0              | 0              | 0              | 0              | 0     | 0     | 1     | 0     |
| 1      | 0              | 1     | 0     | 0              | 0              | 0              | 0              | 0     | 1     | 0     | 0     |
| 1      | 0              | 1     | 1     | 0              | 0              | 0              | 0              | 1     | 0     | 0     | 0     |
| 1      | 1              | 0     | 0     | 0              | 0              | 0              | 1              | 0     | 0     | 0     | 0     |
| 1      | 1              | 0     | 1     | 0              | 0              | 1              | 0              | 0     | 0     | 0     | 0     |
| 1      | 1              | 1     | 0     | 0              | 1              | 0              | 0              | 0     | 0     | 0     | 0     |
| 1      | 1              | 1     | 1     | 1              | 0              | 0              | 0              | 0     | 0     | 0     | 0     |

TABLE 2-1 Truth Table for 3-to-8-Line Decoder

### NAND Gate Decoder

Some decoders are constructed with NAND instead of AND gates. Since a NAND gate produces the AND operation with an inverted output, it becomes more economical to generate the decoder outputs in their complement form. A 2-to-4-line decoder with an enable input constructed with NAND gates is shown in Fig. 2-2. The circuit operates with complemented outputs and a complemented enable input E. The decoder is enabled when E is equal to 0. As indicated by the truth table, only one output is equal to 0 at any given time; the other three outputs are equal to 1. The output whose value is equal to 0 represents the equivalent binary number in inputs  $A_1$  and  $A_0$ . The circuit is disabled when E is equal to 1, regardless of the values of the other two inputs.

Figure 2-2 2-to-4-line decoder with NAND gates.

| E | $A_1$ | $A_0$ | $D_0$ | $D_1$ | $D_2$ | $D_3$ |
|---|-------|-------|-------|-------|-------|-------|
| 0 | 0     | 0     | 0     | 1     | 1     |       |
| 0 | 0     | 1     | 1     | 0     | 1     | 1     |
| 0 | 1     | 0     | 1     | 1     | 0     | 1     |
| 0 | 1     | 1     | 1     | 1     | 1     | 0     |
| 1 | ×     | ×     | 1     | 1     | 1     | 1     |

(b) Truth table

When the circuit is disabled, none of the outputs are selected and all outputs are equal to 1. In general, a decoder may operate with complemented or uncomplemented outputs. The enable input may be activated with a 0 or with a 1 signal level. Some decoders have two or more enable inputs that must satisfy a given logic condition in order to enable the circuit.

## Decoder Expansion

There are occasions when a certain-size decoder is needed but only smaller sizes are available. When this occurs it is possible to combine two or more decoders with enable inputs to form a larger decoder. Thus if a 6-to-64-line decoder is needed, it is possible to construct it with four 4-to-16-line decoders.

Figure 2-3 shows how decoders with enable inputs can be connected to form a larger decoder. Two 2-to-4-line decoders are combined to achieve a 3-to-8-line decoder. The two least significant bits of the input are connected to both decoders. The most significant bit is connected to the enable input of one decoder and through an inverter to the enable input of the other decoder. It is assumed that each decoder is enabled when its E input is equal to 1. When E is equal to 0, the decoder is disabled and all its outputs are in the 0 level. When E is equal to 0, the upper decoder is enabled and the lower is disabled. The lower decoder outputs become inactive with all outputs at 0. The outputs of the upper decoder generate outputs E0 through E1, the lower decoder is enabled and the upper decoder is disabled. The lower decoder output generates the binary equivalent E1 through E2 is disabled. The lower decoder output generates the binary equivalent E3 through E4 through E5 since these binary numbers have a 1 in the E4 position.



Figure 2-3 A 3  $\times$  8 decoder constructed with two 2  $\times$  4 decoders.

The example demonstrates the usefulness of the enable input in decoders or any other combinational logic component. Enable inputs are a convenient feature for interconnecting two or more circuits for the purpose of expanding the digital component into a similar function but with more inputs and outputs.

#### Encoders

An encoder is a digital circuit that performs the inverse operation of a decoder. An encoder has  $2^n$  (or less) input lines and n output lines. The output lines generate the binary code corresponding to the input value. An example of an encoder is the octal-to-binary encoder, whose truth table is given in Table 2-2. It has eight inputs, one for each of the octal digits, and three outputs that generate the corresponding binary number. It is assumed that only one input has a value of 1 at any given time; otherwise, the circuit has no meaning.

| Inputs         |       |                |       |       |                |       |                | Outputs        |       |                |
|----------------|-------|----------------|-------|-------|----------------|-------|----------------|----------------|-------|----------------|
| D <sub>7</sub> | $D_6$ | D <sub>5</sub> | $D_4$ | $D_3$ | D <sub>2</sub> | $D_1$ | D <sub>0</sub> | A <sub>2</sub> | $A_1$ | A <sub>0</sub> |
| 0              | 0     | 0              | 0     | 0     | 0              | 0     | 1              | 0              | 0     | 0              |
| 0              | 0     | 0              | 0     | 0     | 0              | 1     | 0              | 0              | 0     | 1              |
| 0              | 0     | 0              | 0     | 0     | 1              | 0     | 0              | 0              | 1     | 0              |
| 0              | 0     | 0              | 0     | 1     | 0              | 0     | 0              | 0              | 1     | 1              |
| 0              | 0     | 0              | 1     | 0     | 0              | 0     | 0              | 1              | 0     | 0              |
| 0              | 0     | 1              | 0     | 0     | 0              | 0     | 0              | 1              | 0     | 1              |
| 0              | 1     | 0              | 0     | 0     | 0              | 0     | 0              | 1              | 1     | 0              |
| 1              | 0     | 0              | 0     | 0     | 0              | 0     | 0              | 1              | 1     | 1              |

TABLE 2-2 Truth Table for Octal-to-Binary Encoder

The encoder can be implemented with OR gates whose inputs are determined directly from the truth table. Output  $A_0 = 1$  if the input octal digit is 1 or 3 or 5 or 7. Similar conditions apply for the other two outputs. These conditions can be expressed by the following Boolean functions:

$$A_0 = D_1 + D_3 + D_5 + D_7$$

$$A_1 = D_2 + D_3 + D_6 + D_7$$

$$A_2 = D_4 + D_5 + D_6 + D_7$$

The encoder can be implemented with three OR gates.

# 2-3 Multiplexers

multiplexer

A multiplexer is a combinational circuit that receives binary information from one of 2" input data lines and directs it to a single output line. The selection of a particular input data line for the output is determined by a set of selection inputs. A 2"-to-1 multiplexer has 2" input data lines and n input selection lines whose bit combinations determine which input data are selected for the output.

A 4-to-1-line multiplexer is shown in Fig. 2-4. Each of the four data inputs  $I_0$  through  $I_3$  is applied to one input of an AND gate. The two selection inputs  $S_1$  and  $S_0$  are decoded to select a particular AND gate. The outputs of the AND gates are applied to a single OR gate to provide the single output. To demonstrate the circuit operation, consider the case when  $S_1S_0 = 10$ . The AND gate associated with input  $I_2$  has two of its inputs equal to 1. The third input of the gate is connected to  $I_2$ . The other three AND gates have at least one input equal to 0, which makes their outputs equal to 0. The OR gate output is now equal to the value of  $I_2$ , thus providing a path from the selected input to the output.

The 4-to-1 line multiplexer of Fig. 2-4 has six inputs and one output. A truth table describing the circuit needs 64 rows since six input variables can have  $2^6$  binary combinations. This is an excessively long table and will not be shown here. A more convenient way to describe the operation of multiplexers is by means of a function table. The function table for the multiplexer is shown in Table 2-3. The table demonstrates the relationship between the four data inputs and the single output as a function of the selection inputs  $S_1$  and  $S_0$ .



Figure 2-4 4-to-1-line multiplexer.

ista selector

When the selection inputs are equal to 00, output Y is equal to input  $I_0$ . When the selection inputs are equal to 01, input  $I_1$  has a path to output Y, and similarly for the other two combinations. The multiplexer is also called a *data selector*, since it selects one of many data inputs and steers the binary information to the output.

TABLE 2-3 Function Table for 4-to-1-Line Multiplexer

| Sel            | ect | Output         |
|----------------|-----|----------------|
| S <sub>1</sub> | So  | Υ              |
| 0              | 0   | I <sub>o</sub> |
| 0              | 1   | $I_1$          |
| 1              | 0   | $I_2$          |
| 1              | 1   | $I_3$          |

The AND gates and inverters in the multiplexer resemble a decoder circuit, and indeed they decode the input selection lines. In general, a  $2^n$ -to-line multiplexer is constructed from an n-to- $2^n$  decoder by adding to it  $2^n$  input lines, one from each data input. The size of the multiplexer is specified by the number  $2^n$  of its data inputs and the single output. It is then implied that it also contains n input selection lines. The multiplexer is often abbreviated as MUX.

As in decoders, multiplexers may have an enable input to control the operation of the unit. When the enable input is in the inactive state, the outputs are disabled, and when it is in the active state, the circuit functions as a normal multiplexer. The enable input is useful for expanding two or more multiplexers to a multiplexer with a larger number of inputs.

In some cases two or more multiplexers are enclosed within a single integrated circuit package. The selection and the enable inputs in multiple-unit construction are usually common to all multiplexers. As an illustration, the block diagram of a quadruple 2-to-1-line multiplexer is shown in Fig. 2-5. The circuit has four multiplexers, each capable of selecting one of two input lines. Output  $Y_0$  can be selected to come from either input  $A_0$  or  $B_0$ . Similarly, output  $Y_1$  may have the value of  $A_1$  or  $B_1$ , and so on. One input selection line S selects one of the lines in each of the four multiplexers. The enable input E must be active for normal operation. Although the circuit contains four multiplexers, we can also think of it as a circuit that selects one of two 4-bit data lines. As shown in the function table, the unit is enabled when E=1. Then, if S=0, the four A inputs have a path to the four outputs. On the other hand, if S=1, the four B inputs are applied to the outputs. The outputs have all 0's when E=0, regardless of the values of S.



Figure 2-5 Quadruple 2-to-1 line multiplexers.

## 2-6 Binary Counters

A register that goes through a predetermined sequence of states upon the application of input pulses is called a counter. The input pulses may be clock pulses or may originate from an external source. They may occur at uniform intervals of time or at random. Counters are found in almost all equipment containing digital logic. They are used for counting the number of occurrences of an event and are useful for generating timing signals to control the sequence of operations in digital computers.

Of the various sequences a counter may follow, the straight binary sequence is the simplest and most straightforward. A counter that follows the binary number sequence is called a binary counter. An *n*-bit binary counter is a register of *n* flip-flops and associated gates that follows a sequence of states according to the binary count of *n* bits, from 0 to 2" – 1. The design of binary counters can be carried out by the procedure outlined in Sec. 1-7 for sequential circuits. A simpler alternative design procedure may be carried out from a direct inspection of the sequence of states that the register must undergo to achieve a straight binary count.

Going through a sequence of binary numbers such as 0000, 0001, 0010, 0011, and so on, we note that the lower-order bit is complemented after every count and every other bit is complemented from one count to the next if and only if all its lower-order bits are equal to 1. For example, the binary count from 0111 (7) to 1000 (8) is obtained by (a) complementing the low-order bit, (b) complementing the second-order bit because the first bit of 0111 is 1, (c) complementing the third-order bit because the first two bits of 0111 are 1's, and (d) complementing the fourth-order bit because the first three bits of 0111 are all 1's.

A counter circuit will usually employ flip-flops with complementing capabilities. Both T and JK flip-flops have this property. Remember that a JK flip-flop is complemented if both its J and K inputs are 1 and the clock goes through a positive transition. The output of the flip-flop does not change if J = K = 0. In addition, the counter may be controlled with an enable input that turns the counter on or off without removing the clock signal from the flip-flops.

Synchronous binary counters have a regular pattern, as can be seen from the 4-bit binary counter shown in Fig. 2-10. The C inputs of all flip-flops receive the common clock. If the count enable is 0, all J and K inputs are maintained



Figure 2-10 4-bit synchronous binary counter.